Scroll to navigation

UNLINK(2) Linux Programmer's Manual UNLINK(2)

名前

unlink - 名前を削除し、場合によってはそれが参照しているファイルも削除する

書式

#include <unistd.h>

int unlink(const char *pathname);

説明

unlink() はファイルシステム上の名前を削除する。 もしその名前がファイルへの最後のリンク (link) であり、 どのプロセスもそのファイルをオープン (open) していなければ、 ファイルは削除される。 ファイルが使用していたディスク上の領域は再利用が可能になる。

もし削除する名前がファイルへの最後のリンクだが、どれかのプロセスが そのファイルをまだオープンしている場合は、 そのファイルを参照している最後のファイルディスクリプター (file descriptor) がクローズ (close) されるまでファイルは存在し続ける。

もしその名前がシンボリック・リンク (symbolic link) を参照していれば、 リンクは削除される。

もし名前がソケット (socket) や fifo やデバイス (device) を参照していれば 名前は削除されるがそのオブジェクトをオープンしていたプロセスは それを使い続けることができる。

返り値

成功した場合は 0 を返す。エラーならば -1 を返し、 errno が適切に設定される。

エラー

pathname を含んでいるディレクトリの書き込み許可がプロセスの実効 (effective) ユーザー ID に与えられていないか、 pathname の中のディレクトリのどれかに検索許可が与えられていない (path_resolution(7) も参照すること)。
ファイル pathname がシステムまたは他のプロセスによって使用されていて リンクが削除できなかったので、この実装ではエラーとした。
pathname がアクセス可能なアドレス空間の外を指している。
I/O エラーが発生した。
pathname がディレクトリを参照している。 (これは POSIX で規定されていない値で、Linux 2.1.132 以降で返される。)
pathname を解決する際に遭遇したシンボリック・リンクが多過ぎる。
pathname が長過ぎる。
pathname に対応するものが存在しないか、壊れたシンボリック・リンクであるか、 pathname が空である。
十分なカーネル (kernel) のメモリーが使用できない。
pathname のディレクトリ部分が、実際には、ディレクトリでない。
システムがディレクトリに対する unlink 操作を許可していない。 またはディレクトリに対する unlink 操作のために必要な特権を 呼び出し元のプロセスが持っていない。 (これは POSIX で規定されているエラーの返し方である。 上述の通り、この場合には Linux は EISDIR を返す。)
ファイルシステムがファイルに対する unlink 操作を許していない。
pathname を含んでいるディレクトリにスティッキー・ビット (sticky-bit) (S_ISVTX) が設定されていて、プロセスの実効ユーザー ID が削除しようとするファイルの UID でもそれを含んでいるディレクトリのものでもなく、 かつプロセスに特権がない (Linux では CAP_FOWNER ケーパビリティ (capability) がない)。
pathname が読み込み専用のファイルシステムのファイルを参照している。

準拠

SVr4, 4.3BSD, POSIX.1-2001.

バグ

NFS プロトコル (protocol) の潜在的な不良により、 まだ使用中のファイルの突然の消滅を引き起こすことがある。

関連項目

rm(1), chmod(2), link(2), mknod(2), open(2), rename(2), rmdir(2), unlinkat(2), mkfifo(3), remove(3), path_resolution(7), symlink(7)

2004-06-23 Linux